查看原文
其他

Seurat2和Seurat3共存的方法

徐洲更 单细胞天地 2022-06-07

分享是一种态度

软件升级虽然是一件值得高兴的是,但是代码变化太大却不是一件好消息。比如说Seurat,这个单细胞分析最常用的R包,它的2.x版本和3.x版本的变化就是翻天覆地。

为了能够重现别人的代码,你可能需要重装2.3.4版本的Seurat,官方提供了安装脚本

1source("https://gist.githubusercontent.com/satijalab/beb9bb50dedc75ee023bd5d9be5fe684/raw/e103577735a2fba9da2ccca14ce1ac33e46c1bc4/old_seurat.R")

但是在window下安装会出一个报错, 提示无法在Windows下安装MacOS的版本

这个时候需要手动安装Seurat,注意,这里要求有Rtools才能进行编译

1install.packages('Seurat', repos = 'https://satijalab.org/ran'type = "source")

可以设置install.packages里的参数lib.loc,让Seurat安装到其他的文件加,就不会替换原来的Seurat,同时用library加载的时候,也需要设置lib.loc.

上面是简单可行易操作的方法,唯一的问题是你不能同时加载两个Seurat版本,当然你也不会想这样子做,所以这是一个伪需求。

下面就是瞎折腾环节, 我要将Seurat的2.3.4版本单独搞出一个R包,Seurat2,这样子就可以同时加载这两个R包。

下载Seurat 2.3.4

1wget https://satijalab.org/ran/src/contrib/Seurat_2.3.4.tar.gz

解压缩它

1tar xf Seurat_2.3.4.tar.gz
2cd Seurat

删除MD5文件,因为它会做文件检验

1rm MD5

修改里面所有的Seurat替换成Seurat2, seurat替换成seurat2

1find . -type f -print0 | xargs -0 sed -i "s/Seurat/Seurat2/g"
2find . -type f -print0 | xargs -0 sed -i "s/seurat/seurat2/g"

这种无差别的替换会有一个问题,会把一些这类http://www.satijalab.org/seurat非代码信息中的seurat替换成seurat2,不过这并不影响实际函数的使用。

R/seurat.R重名为R/seurat2.R

1mv R/seurat.R R/seurat2.R

之后将修改的文件进行打包

就能用install.packages("Seurat2.tar.gz",repos=NULL,type="source")

进行安装了

1tar -czf Seurat2.tar.gz Seurat

注意: 目前未修改测试数据集的对象,所以不能用Seurat2来运行pbmc_small的例子

目前我将其上传到GitHub,所以可以用devtools进行安装。由于代码只是简单修改,存在bug,不建议尝试使用。

1devtools::install_github("xuzhougeng/Seurat2")

代码测试,数据来自文献https://www.nature.com/articles/srep39921

1library(Seurat)
2library(Seurat2)
3
4molecules <- read.delim("~/tung/molecules.txt",header = TRUE,
5                        row.names = 1)
6
7# 使用Seurat2进行分析
8obj <- CreateSeurat2Object(raw.data = molecules, 
9                          min.cells = 3, #筛选至少在3个细胞中表达的基因
10                          min.genes = 200) #筛选至少有200个基因表达的细胞
11obj <- FilterCells(obj, 
12                   subset.names = c("nUMI","nGene"), 
13                   low.thresholds = c(25000, 6000),
14                   high.thresholds = c(Inf, Inf))
15obj <- NormalizeData(
16  object = obj, 
17  normalization.method = "LogNormalize", 
18  scale.factor = 10000
19)
20
21obj <- FindVariableGenes(
22  object = obj,
23  mean.function = ExpMean, #计算x轴的值的方法
24  dispersion.function = LogVMR, #计算y轴的值的方法
25  do.plot = F,
26  x.low.cutoff = 0.0125, 
27  x.high.cutoff = 3, 
28  y.cutoff = 0.5
29)
30
31obj <- ScaleData(
32  object = obj, 
33  vars.to.regress = c("nUMI")
34)
35
36obj <- RunPCA(
37  object = obj, 
38  pc.genes = obj@var.genes, 
39  do.print = FALSE
40)
41
42pca_to_use <- 14 #上一步主成分的个数
43obj <- FindClusters(
44  object = obj, 
45  reduction.type = "pca", 
46  dims.use = 1:pca_to_use,  # 
47  resolution = 1.0, 
48  print.output = 0, 
49  save.SNN = TRUE
50)
51



往期回顾

Monocle2 踩坑教程(2)

Monocle2 踩坑教程(1)

差异分析及KEGG注释简介

单细胞测序助力研究宿主细胞和病原体之间的关系

乳腺癌转移过程中的异常发育途径

sc-RAN-seq 数据分析||Seurat新版教程:整合分析

骨髓龛中不同细胞群体的关联性及其分化途径

Seurat新版教程:Guided Clustering Tutorial-(下)

Seurat新版教程:Guided Clustering Tutorial-(上)






如果你对单细胞转录组研究感兴趣,但又不知道如何入门,也许你可以关注一下下面的课程



看完记得顺手点个“在看”哦!


生物 | 单细胞 | 转录组丨资料每天都精彩

长按扫码可关注



您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存